~ chicken-core (master) /manual/Module (chicken base)


   1[[tags: manual]]
   2[[toc:]]
   3
   4== Module (chicken base)
   5
   6Core procedures and macros, acting as basic extensions to the R7RS
   7standard and other essential features.
   8
   9This module is used by default, unless a program is compiled with
  10the {{-explicit-use}} option.
  11
  12=== Numeric predicates
  13
  14These allow you to make a more precise differentiation between number
  15types and their properties, not provided by R7RS.
  16
  17==== fixnum?
  18
  19<procedure>(fixnum? X)</procedure>
  20
  21Returns {{#t}} if {{X}} is a fixnum, or {{#f}} otherwise.
  22
  23==== flonum?
  24
  25<procedure>(flonum? X)</procedure>
  26
  27Returns {{#t}} if {{X}} is a flonum, or {{#f}} otherwise.
  28
  29==== bignum?
  30
  31<procedure>(bignum? X)</procedure>
  32
  33Returns {{#t}} if {{X}} is a bignum (integer larger than fits in a
  34fixnum), or {{#f}} otherwise.
  35
  36==== exact-integer?
  37
  38<procedure>(exact-integer? X)</procedure>
  39
  40Returns {{#t}} if {{X}} is an exact integer (i.e., a fixnum or a
  41bignum), or {{#f}} otherwise.
  42
  43This procedure is compatible with the definition from the R7RS
  44{{(scheme base)}} library.
  45
  46==== cplxnum?
  47
  48<procedure>(cplxnum? X)</procedure>
  49
  50Returns {{#t}} if {{X}} is a true complex number (it has an imaginary
  51component), or {{#f}} otherwise.
  52
  53Please note that {{complex?}} will always return {{#t}} for any number
  54type supported by CHICKEN, so you can use this predicate if you want
  55to know the representational type of a number.
  56
  57==== ratnum?
  58
  59<procedure>(ratnum? X)</procedure>
  60
  61Returns {{#t}} if {{X}} is a true rational number (it is a fraction
  62with a denominator that's not 1), or {{#f}} otherwise.
  63
  64Please note that {{rational?}} will always return {{#t}} for any
  65number type supported by CHICKEN except complex numbers and non-finite
  66flonums, so you can use this predicate if you want to know the
  67representational type of a number.
  68
  69==== nan?
  70
  71<procedure>(nan? N)</procedure>
  72
  73Returns {{#t}} if {{N}} is not a number (a IEEE flonum NaN-value).  If
  74{{N}} is a complex number, it's considered nan if it has a real or
  75imaginary component that's nan.
  76
  77This procedure is compatible with the definition from the R7RS
  78{{(scheme inexact)}} library.
  79
  80==== infinite?
  81
  82<procedure>(infinite? N)</procedure>
  83
  84Returns {{#t}} if {{N}} is negative or positive infinity, and {{#f}}
  85otherwise.  If {{N}} is a complex number, it's considered infinite if
  86it has a real or imaginary component that's infinite.
  87
  88This procedure is compatible with the definition from the R7RS
  89{{(scheme inexact)}} library.
  90
  91==== finite?
  92
  93<procedure>(finite? N)</procedure>
  94
  95Returns {{#t}} if {{N}} represents a finite number and {{#f}}
  96otherwise.  Positive and negative infinity as well as NaNs are not
  97considered finite.  If {{N}} is a complex number, it's considered
  98finite if both the real and imaginary components are finite.
  99
 100This procedure is compatible with the definition from the R7RS
 101{{(scheme inexact)}} library.
 102
 103==== equal=?
 104
 105<procedure>(equal=? X y)</procedure>
 106
 107Similar to the standard procedure {{equal?}}, but compares numbers
 108using the {{=}} operator, so {{equal=?}} allows structural comparison
 109in combination with comparison of numerical data by value.
 110
 111
 112=== Arithmetic
 113
 114==== add1/sub1
 115
 116<procedure>(add1 N)</procedure>
 117<procedure>(sub1 N)</procedure>
 118
 119Adds/subtracts 1 from {{N}}.
 120
 121
 122==== exact-integer-nth-root
 123
 124<procedure>(exact-integer-nth-root K N)</procedure>
 125
 126Like {{exact-integer-sqrt}}, but with any base value.  Calculates
 127{{\sqrt[N]{K}}}, the {{N}}th root of {{K}} and returns two values
 128{{s}} and {{r}} where {{s^N + r = K}} and {{K < (s+1)^N}}.
 129
 130
 131==== Division with quotient and remainder
 132
 133<procedure>(quotient&remainder X Y)</procedure>
 134<procedure>(quotient&modulo X Y)</procedure>
 135
 136Returns two values: the quotient and the remainder (or modulo) of
 137{{X}} divided by {{Y}}.  Could be defined as {{(values (quotient X Y)
 138(remainder X Y))}}, but is much more efficient when dividing very
 139large numbers.
 140
 141==== signum
 142
 143<procedure>(signum N)</procedure>
 144
 145For real numbers, returns {{1}} if {{N}} is positive, {{-1}} if {{N}}
 146is negative or {{0}} if {{N}} is zero. {{signum}} is exactness
 147preserving.
 148
 149For complex numbers, returns a complex number of the same angle but
 150with magnitude 1.
 151
 152
 153=== Weak pairs
 154
 155''Weak pairs'' behave identically to regular pairs, with one
 156exception: the car value may be garbage collected.  When that happens,
 157it gets replaced with a sentinel "broken-weak-pointer" value.
 158
 159They are indistinguishable from regular pairs: {{car}}, {{cdr}}, etc
 160all work on them, {{pair?}} returns true, etc.  The {{WRITE}}
 161representation is identical to regular pairs, so they will be read
 162back as pairs.  In other words, they have no read/write invariance.
 163
 164They're the same as regular pairs for all intents and purposes.
 165However, there's a {{weak-pair?}} predicate which ''can'' distinguish
 166between regular pairs and weak pairs.
 167
 168NOTE: Due to internal limitations, {{set-car!}} on a weak pair
 169currently may cause it to hold onto the value for one more GC cycle in
 170some situations.
 171
 172==== weak-cons
 173
 174<procedure>(weak-cons obj[1] obj[2])</procedure><br>
 175
 176Returns a newly allocated weak pair whose car is obj[1] and whose cdr
 177is obj[2]. The pair is indistinguishable from normal pairs, except as
 178noted above.
 179
 180 (weak-cons 'a '())                   ===>  (a)
 181 (weak-cons '(a) '(b c d))            ===>  ((a) b c d)
 182 (weak-cons "a" '(b c))               ===>  ("a" b c)
 183 (weak-cons 'a 3)                     ===>  (a . 3)
 184 (weak-cons '(a b) 'c)                ===>  ((a b) . c)
 185
 186 (import (chicken gc))
 187
 188 (let* ((x '(a b))
 189        (y (weak-cons x 'c)))
 190   (gc #t)
 191   (car x))                           ===> (a b)
 192
 193 (let ((x (weak-cons '(a b) 'c)))
 194   (gc #t)
 195   (car x))                           ===>  #!bwp
 196
 197As the final two examples show, when something ''else'' still holds on
 198to the value that's stored in the car of a weak pair, it will not be
 199reclaimed.  But if the value is ''only'' referenced by one or more
 200weak pairs, it is reclaimed and the car of the weak pair is replaced
 201with the ''broken-weak-pointer'' value {{#!bwp}}.
 202
 203<procedure>(weak-pair? obj)</procedure><br>
 204
 205This predicate returns {{#t}} if and only if {{obj}} is a weak pair.
 206
 207 (weak-pair? (weak-cons 'a '()))      ===>  #t
 208 (weak-pair? (cons 'a '()))           ===>  #f
 209 (weak-pair? (vector 'a '()))         ===>  #f
 210
 211<procedure>(bwp-object? obj)</procedure>
 212
 213This predicate returns {{#t}} if {{obj}} is the broken-weak-pointer
 214value, otherwise {{#f}}.
 215
 216
 217=== Input/Output
 218
 219==== current-error-port
 220
 221<procedure>(current-error-port [PORT])</procedure>
 222
 223Returns default error output port. If {{PORT}} is given, then that
 224port is selected as the new current error output port.
 225
 226Note that the default error output port is not buffered. Use
 227[[Module (chicken port)#set-buffering-mode!|{{set-buffering-mode!}}]]
 228if you need a different behaviour.
 229
 230==== print
 231
 232<procedure>(print [EXP1 ...])</procedure>
 233
 234Outputs the optional arguments {{EXP1 ...}} using {{display}} and
 235writes a newline character to the port that is the value of
 236{{(current-output-port)}}. Returns {{(void)}}.
 237
 238==== print*
 239
 240<procedure>(print* [EXP1 ...])</procedure>
 241
 242Similar to {{print}}, but does not output a terminating newline
 243character and performs a {{flush-output}} after writing its arguments.
 244
 245
 246=== Interrupts and error-handling
 247
 248==== enable-warnings
 249
 250<procedure>(enable-warnings [BOOL])</procedure>
 251
 252Enables or disables warnings, depending on wether {{BOOL}} is true or
 253false.  If called with no arguments, this procedure returns {{#t}} if
 254warnings are currently enabled, or {{#f}} otherwise. Note that this is
 255not a parameter.  The current state (whether warnings are enabled or
 256disabled) is global and not thread-local.
 257
 258
 259==== error
 260
 261<procedure>(error [LOCATION] [STRING] EXP ...)</procedure>
 262
 263Prints error message, writes all extra arguments to the value of
 264{{(current-error-port)}} and invokes the current
 265exception-handler. This conforms to
 266[[http://srfi.schemers.org/srfi-23/srfi-23.html|SRFI-23]].  If
 267{{LOCATION}} is given and a symbol, it specifies the ''location'' (the
 268name of the procedure) where the error occurred.
 269
 270
 271==== assert
 272
 273<macro>(assert EXP [OBJ ...])</macro>
 274
 275Evaluates {{EXP}}, if it returns #f, {{error}} is applied to {{OBJ ...}},
 276else the result of {{EXP}} is returned.
 277When compiling in unsafe mode, assertions of this kind are disabled.
 278
 279
 280==== get-call-chain
 281
 282<procedure>(get-call-chain [START [THREAD]])</procedure>
 283
 284Returns a list with the call history. Backtrace information is only
 285generated in code compiled without {{-no-trace}} and evaluated code.
 286If the optional argument {{START}} is given, the backtrace starts at
 287this offset, i.e. when {{START}} is 1, the next to last trace-entry is
 288printed, and so on. If the optional argument {{THREAD}} is given, then
 289the call-chain will only be constructed for calls performed by this
 290thread.
 291
 292
 293
 294==== print-call-chain
 295
 296<procedure>(print-call-chain [PORT [START [THREAD [HEADER]]]])</procedure>
 297
 298Prints a backtrace of the procedure call history to {{PORT}}, which
 299defaults to {{(current-output-port)}}. The output is prefixed by the
 300{{HEADER}}, which defaults to {{"\n\tCall history:\n"}}.
 301
 302
 303==== procedure-information
 304
 305<procedure>(procedure-information PROC)</procedure>
 306
 307Returns an s-expression with debug information for the procedure
 308{{PROC}}, or {{#f}}, if {{PROC}} has no associated debug information.
 309
 310
 311==== warning
 312
 313<procedure>(warning MESSAGE [EXP ...])</procedure>
 314
 315Displays a warning message (if warnings are enabled with {{enable-warnings}}),
 316from the {{MESSAGE}}, and optional {{EXP}} arguments, then continues execution.
 317{{MESSAGE}}, and {{EXP}}, may be {{any}} object.
 318
 319
 320=== Lists
 321
 322==== alist-ref
 323
 324<procedure>(alist-ref KEY ALIST [TEST [DEFAULT]])</procedure>
 325
 326Looks up {{KEY}} in {{ALIST}} using {{TEST}} as the comparison function (or {{eqv?}} if
 327no test was given) and returns the cdr of the found pair, or {{DEFAULT}} (which defaults to {{#f}}).
 328
 329
 330==== alist-update
 331
 332<procedure>(alist-update KEY VALUE ALIST [TEST])</procedure>
 333<procedure>(alist-update! KEY VALUE ALIST [TEST])</procedure>
 334
 335If the list {{ALIST}} contains a pair of the form {{(KEY . X)}}, then this procedure
 336replaces {{X}} with {{VALUE}} and returns {{ALIST}}. If {{ALIST}} contains no such item, then
 337{{alist-update}} returns {{((KEY . VALUE) . ALIST)}}. The optional argument
 338{{TEST}} specifies the comparison procedure to search a matching pair in {{ALIST}}
 339and defaults to {{eqv?}}. {{alist-update!}} is the destructive version of {{alist-update}}.
 340
 341
 342==== atom?
 343
 344<procedure>(atom? X)</procedure>
 345
 346Returns {{#t}} if {{X}} is not a pair.
 347
 348
 349==== butlast
 350
 351<procedure>(butlast LIST)</procedure>
 352
 353Returns a fresh list with all elements but the last of {{LIST}}.
 354
 355
 356==== chop
 357
 358<procedure>(chop LIST N)</procedure>
 359
 360Returns a new list of sublists, where each sublist contains {{N}}
 361elements of {{LIST}}. If {{LIST}} has a length that is not
 362a multiple of {{N}}, then the last sublist contains the remaining
 363elements.
 364
 365<enscript highlight=scheme>
 366(chop '(1 2 3 4 5 6) 2) ==> ((1 2) (3 4) (5 6))
 367(chop '(a b c d) 3)     ==> ((a b c) (d))
 368</enscript>
 369
 370
 371==== compress
 372
 373<procedure>(compress BLIST LIST)</procedure>
 374
 375Returns a new list with elements taken from {{LIST}} with
 376corresponding true values in the list {{BLIST}}.
 377
 378<enscript highlight=scheme>
 379(define nums '(99 100 110 401 1234))
 380(compress (map odd? nums) nums)      ==> (99 401)
 381</enscript>
 382
 383
 384==== flatten
 385
 386<procedure>(flatten LIST1 ...)</procedure>
 387
 388Returns {{LIST1 ...}} concatenated together, with nested lists
 389removed (flattened).
 390
 391
 392==== foldl
 393
 394<procedure>(foldl PROCEDURE INIT LIST)</procedure>
 395
 396Applies {{PROCEDURE}} to the elements from {{LIST}}, beginning from
 397the left:
 398
 399<enscript hightlight=scheme>
 400(foldl + 0 '(1 2 3))    ==>    (+ (+ (+ 0 1) 2) 3)
 401</enscript>
 402
 403Note that the order of arguments taken by {{PROCEDURE}} is different
 404from the {{SRFI-1}} {{fold}} procedure, but matches the more natural
 405order used in Haskell and Objective Caml.
 406
 407
 408==== foldr
 409
 410<procedure>(foldr PROCEDURE INIT LIST)</procedure>
 411
 412Applies {{PROCEDURE}} to the elements from {{LIST}}, beginning from
 413the right:
 414
 415<enscript hightlight=scheme>
 416(foldr + 0 '(1 2 3))    ==>    (+ 1 (+ 2 (+ 3 0)))
 417</enscript>
 418
 419
 420==== intersperse
 421
 422<procedure>(intersperse LIST X)</procedure>
 423
 424Returns a new list with {{X}} placed between each element.
 425
 426
 427==== join
 428
 429<procedure>(join LISTOFLISTS [LIST])</procedure>
 430
 431Concatenates the lists in {{LISTOFLISTS}} with {{LIST}} placed
 432between each sublist. {{LIST}} defaults to the empty list.
 433
 434<enscript highlight=scheme>
 435(join '((a b) (c d) (e)) '(x y)) ==> (a b x y c d x y e)
 436(join '((p q) () (r (s) t)) '(-))  ==> (p q - - r (s) t)
 437</enscript>
 438
 439{{join}} could be implemented as follows:
 440
 441<enscript highlight=scheme>
 442(define (join lstoflsts #!optional (lst '()))
 443  (apply append (intersperse lstoflists lst)) )
 444</enscript>
 445
 446
 447==== rassoc
 448
 449<procedure>(rassoc KEY LIST [TEST])</procedure>
 450
 451Similar to {{assoc}}, but compares {{KEY}} with the {{cdr}} of each pair in {{LIST}} using
 452{{TEST}} as the comparison procedures (which defaults to {{eqv?}}).
 453
 454
 455==== tail?
 456
 457<procedure>(tail? X LIST)</procedure>
 458
 459Returns true if {{X}} is one of the tails (cdr's) of {{LIST}}.
 460
 461
 462=== Vectors
 463
 464==== vector-resize
 465
 466<procedure>(vector-resize VECTOR N [INIT])</procedure>
 467
 468Creates and returns a new vector with the contents of {{VECTOR}} and
 469length {{N}}. If {{N}} is greater than the original length of
 470{{VECTOR}}, then all additional items are initialized to {{INIT}}. If
 471{{INIT}} is not specified, the contents are initialized to some
 472unspecified value.
 473
 474
 475==== subvector
 476
 477<procedure>(subvector VECTOR FROM [TO])</procedure>
 478
 479Returns a new vector with elements taken from {{VECTOR}} in the
 480given range. {{TO}} defaults to {{(vector-length VECTOR)}}.
 481
 482{{subvector}} was introduced in CHICKEN 4.7.3.
 483
 484
 485=== Combinators
 486
 487
 488==== constantly
 489
 490<procedure>(constantly X ...)</procedure>
 491
 492Returns a procedure that always returns the values {{X ...}} regardless of the number and value of its arguments.
 493
 494<enscript highlight=scheme>
 495(constantly X) <=> (lambda args X)
 496</enscript>
 497
 498
 499==== complement
 500
 501<procedure>(complement PROC)</procedure>
 502
 503Returns a procedure that returns the boolean inverse of {{PROC}}.
 504
 505<enscript highlight=scheme>
 506(complement PROC) <=> (lambda (x) (not (PROC x)))
 507</enscript>
 508
 509
 510==== compose
 511
 512<procedure>(compose PROC1 PROC2 ...)</procedure>
 513
 514Returns a procedure that represents the composition of the
 515argument-procedures {{PROC1 PROC2 ...}}.
 516
 517<enscript highlight=scheme>
 518(compose F G) <=> (lambda args
 519                      (call-with-values
 520                         (lambda () (apply G args))
 521                         F))
 522</enscript>
 523
 524{{(compose)}} is equivalent to {{values}}.
 525
 526
 527==== conjoin
 528
 529<procedure>(conjoin PRED ...)</procedure>
 530
 531Returns a procedure that returns {{#t}} if its argument satisfies the
 532predicates {{PRED ...}}.
 533<enscript highlight=scheme>
 534((conjoin odd? positive?) 33)   ==>  #t
 535((conjoin odd? positive?) -33)  ==>  #f
 536</enscript>
 537
 538
 539==== disjoin
 540
 541<procedure>(disjoin PRED ...)</procedure>
 542
 543Returns a procedure that returns {{#t}} if its argument satisfies any
 544predicate {{PRED ...}}.
 545<enscript highlight=scheme>
 546((disjoin odd? positive?) 32)    ==>  #t
 547((disjoin odd? positive?) -32)   ==>  #f
 548</enscript>
 549
 550
 551==== each
 552
 553<procedure>(each PROC ...)</procedure>
 554
 555Returns a procedure that applies {{PROC ...}} to its arguments, and returns the result(s)
 556of the last procedure application. For example
 557
 558<enscript highlight=scheme>
 559(each pp eval)
 560</enscript>
 561
 562is equivalent to
 563
 564<enscript highlight=scheme>
 565(lambda args
 566  (apply pp args)
 567  (apply eval args) )
 568</enscript>
 569
 570{{(each PROC)}} is equivalent to {{PROC}} and {{(each)}} is equivalent to
 571{{void}}.
 572
 573
 574==== flip
 575
 576<procedure>(flip PROC)</procedure>
 577
 578Returns a two-argument procedure that calls {{PROC}} with its
 579arguments swapped:
 580<enscript highlight=scheme>
 581(flip PROC) <=> (lambda (x y) (PROC y x))
 582</enscript>
 583
 584
 585==== identity
 586
 587<procedure>(identity X)</procedure>
 588
 589Returns its sole argument {{X}}.
 590
 591
 592==== list-of?
 593
 594<procedure>(list-of? PRED)</procedure>
 595
 596Returns a procedure of one argument that returns {{#t}} when
 597applied to a list of elements that all satisfy the predicate procedure
 598{{PRED}}, or {{#f}} otherwise.
 599
 600<enscript highlight=scheme>
 601((list-of? even?) '(1 2 3))   ==> #f
 602((list-of? number?) '(1 2 3)) ==> #t
 603</enscript>
 604
 605
 606==== o
 607
 608<procedure>(o PROC ...)</procedure>
 609
 610A single value version of {{compose}} (slightly faster). {{(o)}} is equivalent
 611to {{identity}}.
 612
 613
 614=== User-defined named characters
 615
 616==== char-name
 617
 618<procedure>(char-name SYMBOL-OR-CHAR [CHAR])</procedure>
 619
 620This procedure can be used to inquire about character names or to
 621define new ones. With a single argument the behavior is as follows:
 622If {{SYMBOL-OR-CHAR}} is a symbol, then {{char-name}} returns
 623the character with this name, or {{#f}} if no character is defined
 624under this name. If {{SYMBOL-OR-CHAR}} is a character, then the
 625name of the character is returned as a symbol, or {{#f}} if the
 626character has no associated name.
 627
 628If the optional argument {{CHAR}} is provided, then
 629{{SYMBOL-OR-CHAR}} should be a symbol that will be the new name of
 630the given character. If multiple names designate the same character,
 631then the {{write}} will use the character name that was defined last.
 632
 633<enscript highlight=scheme>
 634(char-name 'space)                  ==> #\space
 635(char-name #\space)                 ==> space
 636(char-name 'bell)                   ==> #f
 637(char-name (integer->char 7))       ==> #f
 638(char-name 'bell (integer->char 7))
 639(char-name 'bell)                   ==> #\bell
 640(char->integer (char-name 'bell))   ==> 7
 641</enscript>
 642
 643
 644=== The unspecified value
 645
 646==== void
 647
 648<procedure>(void ARGUMENT ...)</procedure>
 649
 650Ignores {{ARGUMENT ...}} and returns an unspecified value.
 651
 652
 653=== Continuations
 654
 655==== call/cc
 656
 657<procedure>(call/cc PROCEDURE)</procedure>
 658
 659An alias for {{call-with-current-continuation}}.
 660
 661This procedure is compatible with the definition from the R7RS
 662{{(scheme base)}} library.
 663
 664=== Symbols
 665
 666==== Symbol utilities
 667
 668===== symbol-append
 669
 670<procedure>(symbol-append SYMBOL1 ...)</procedure>
 671
 672Creates a new symbol from the concatenated names of the argument symbols
 673{{(SYMBOL1 ...)}}.
 674
 675==== Uninterned symbols ("gensyms")
 676
 677Symbols may be "interned" or "uninterned". Interned symbols are
 678registered in a global table, and when read back from a port are
 679identical to a symbol written before:
 680
 681<enscript highlight=scheme>
 682(define sym 'foo)
 683
 684(eq? sym (with-input-from-string
 685            (with-output-to-string
 686              (lambda () (write sym)))
 687	    read))
 688
 689  => #t
 690</enscript>
 691
 692Uninterned symbols on the other hand are not globally registered and so
 693multiple symbols with the same name may coexist:
 694
 695<enscript highlight=scheme>
 696(define sym (gensym 'foo))   ; sym is a uninterned symbol like "foo42"
 697
 698(eq? sym (with-input-from-string    ; the symbol read will be an interned symbol
 699            (with-output-to-string
 700              (lambda () (write sym)))
 701	    read))
 702
 703  => #f
 704
 705(eq? (string->uninterned-symbol "foo") (string->uninterned-symbol "foo"))
 706
 707  => #f
 708</enscript>
 709
 710Use uninterned symbols if you need to generate unique values that
 711can be compared quickly, for example as keys into a hash-table
 712or association list. Note that uninterned symbols lose their
 713uniqueness property when written to a file and read back in, as
 714in the example above.
 715
 716===== gensym
 717
 718<procedure>(gensym [STRING-OR-SYMBOL])</procedure>
 719
 720Returns a newly created uninterned symbol. If an argument is provided,
 721the new symbol is prefixed with that argument.
 722
 723
 724===== string->uninterned-symbol
 725
 726<procedure>(string->uninterned-symbol STRING)</procedure>
 727
 728Returns a newly created, unique symbol with the name {{STRING}}.
 729
 730
 731=== Setters
 732
 733SRFI-17 is fully implemented. For more information see:
 734[[http://srfi.schemers.org/srfi-17/srfi-17.html|SRFI-17]].
 735
 736==== setter
 737
 738<procedure>(setter PROCEDURE)</procedure>
 739
 740Returns the setter-procedure of {{PROCEDURE}}, or signals an error if
 741{{PROCEDURE}} has no associated setter-procedure.
 742
 743Note that {{(set! (setter PROC) ...)}} for a procedure that has no
 744associated setter procedure yet is a very slow operation (the old
 745procedure is replaced by a modified copy, which involves a garbage
 746collection).
 747
 748
 749==== getter-with-setter
 750
 751<procedure>(getter-with-setter GETTER SETTER)</procedure>
 752
 753Returns a copy of the procedure {{GETTER}} with the associated setter
 754procedure {{SETTER}}. Contrary to the SRFI specification, the setter
 755of the returned procedure may be changed.
 756
 757
 758=== Binding forms for optional arguments
 759
 760==== optional
 761
 762<macro>(optional ARGS DEFAULT)</macro>
 763
 764Use this form for procedures that take a single optional argument. If
 765{{ARGS}} is the empty list {{DEFAULT}} is evaluated and
 766returned, otherwise the first element of the list {{ARGS}}. It is
 767an error if {{ARGS}} contains more than one value.
 768
 769<enscript highlight=scheme>
 770(define (incr x . i) (+ x (optional i 1)))
 771(incr 10)                                   ==> 11
 772(incr 12 5)                                 ==> 17
 773</enscript>
 774
 775
 776==== let-optionals
 777
 778<macro> (let-optionals ARGS ((VAR1 DEFAULT1) ...) BODY ...)</macro>
 779
 780Binding constructs for optional procedure arguments. {{ARGS}} is
 781normally a rest-parameter taken from a lambda-list. {{let-optionals}}
 782binds {{VAR1 ...}} to available arguments in parallel, or to
 783{{DEFAULT1 ...}} if not enough arguments were provided.
 784{{let-optionals*}} binds {{VAR1 ...}} sequentially, so every variable
 785sees the previous ones. it is an error if any excess arguments are
 786provided.
 787
 788<enscript highlight=scheme>
 789(let-optionals '(one two) ((a 1) (b 2) (c 3))
 790  (list a b c) )                               ==> (one two 3)
 791</enscript>
 792
 793==== let-optionals*
 794
 795<macro> (let-optionals* ARGS ((VAR1 DEFAULT1) ... [RESTVAR]) BODY ...)</macro>
 796
 797Binding constructs for optional procedure arguments. {{ARGS}} is
 798normally a rest-parameter taken from a lambda-list. {{let-optionals}}
 799binds {{VAR1 ...}} to available arguments in parallel, or to
 800{{DEFAULT1 ...}} if not enough arguments were provided.
 801{{let-optionals*}} binds {{VAR1 ...}} sequentially, so every variable
 802sees the previous ones. If a single variable {{RESTVAR}} is given,
 803then it is bound to any remaining arguments, otherwise it is an error
 804if any excess arguments are provided.
 805
 806<enscript highlight=scheme>
 807(let-optionals* '(one two) ((a 1) (b 2) (c a))
 808  (list a b c) )                               ==> (one two one)
 809</enscript>
 810
 811=== Other binding forms
 812
 813==== and-let*
 814
 815<macro>(and-let* (BINDING ...) EXP1 EXP2 ...)</macro>
 816
 817Bind sequentially and execute body. {{BINDING}} can
 818be a list of a variable and an expression, a list with a single
 819expression, or a single variable. If the value of an expression
 820bound to a variable is {{#f}}, the {{and-let*}} form
 821evaluates to {{#f}} (and the subsequent bindings and the body
 822are not executed).  Otherwise the next binding is performed. If
 823all bindings/expressions evaluate to a true result, the body is
 824executed normally and the result of the last expression is the
 825result of the {{and-let*}} form. See also the documentation for
 826[[http://srfi.schemers.org/srfi-2/srfi-2.html|SRFI-2]].
 827
 828==== letrec*
 829
 830<macro>(letrec* ((VARIABLE EXPRESSION) ...) BODY ...)</macro>
 831
 832Implements R6RS/R7RS {{letrec*}}. {{letrec*}} is similar to {{letrec}}
 833but binds the variables sequentially and is to {{letrec}} what
 834{{let*}} is to {{let}}.
 835
 836This special form is compatible with the definition from the R7RS
 837{{(scheme base)}} library.
 838
 839==== rec
 840
 841<macro>(rec NAME EXPRESSION)</macro><br>
 842<macro>(rec (NAME VARIABLE ...) BODY ...)</macro>
 843
 844Allows simple definition of recursive definitions. {{(rec NAME EXPRESSION)}} is
 845equivalent to {{(letrec ((NAME EXPRESSION)) NAME)}} and {{(rec (NAME VARIABLE ...) BODY ...)}}
 846is the same as {{(letrec ((NAME (lambda (VARIABLE ...) BODY ...))) NAME)}}.
 847
 848==== cut
 849
 850<macro>(cut SLOT ...)</macro><br>
 851<macro>(cute SLOT ...)</macro>
 852
 853[[http://srfi.schemers.org/srfi-26/srfi-26.html|Syntactic sugar for specializing parameters]].
 854
 855==== define-values
 856
 857<macro>(define-values (NAME ...) VALUEEXP)</macro>
 858<macro>(define-values (NAME1 ... NAMEn . NAMEn+1) VALUEEXP)</macro>
 859<macro>(define-values NAME VALUEEXP)</macro>
 860
 861Defines several variables at once, with the result values of expression
 862{{VALUEEXP}}, similar to {{set!-values}}.
 863
 864This special form is compatible with the definition from the R7RS
 865{{(scheme base)}} library.
 866
 867==== fluid-let
 868
 869<macro>(fluid-let ((VAR1 X1) ...) BODY ...)</macro>
 870
 871Binds the variables {{VAR1 ...}} dynamically to the values {{X1 ...}}
 872during execution of {{BODY ...}}.  This implements
 873[[http://srfi.schemers.org/srfi-15/srfi-15.html|SRFI-15]].
 874
 875==== let-values
 876
 877<macro>(let-values (((NAME ...) VALUEEXP) ...) BODY ...)</macro>
 878
 879Binds multiple variables to the result values of {{VALUEEXP ...}}.
 880All variables are bound simultaneously.  Like {{define-values}}, the
 881{{(NAME ...)}} expression can be any basic lambda list (dotted tail
 882notation is supported).
 883
 884This special form implements
 885[[http://srfi.schemers.org/srfi-11/srfi-11.html|SRFI-11]], and it is
 886also compatible with the definition from the R7RS {{(scheme base)}}
 887library.
 888
 889
 890==== let*-values
 891
 892<macro>(let*-values (((NAME ...) VALUEEXP) ...) BODY ...)</macro>
 893
 894Binds multiple variables to the result values of {{VALUEEXP ...}}.
 895The variables are bound sequentially.  Like {{let-values}}, the
 896{{(NAME ...)}} expression can be any basic lambda list (dotted tail
 897notation is supported).
 898
 899This is also part of
 900[[http://srfi.schemers.org/srfi-11/srfi-11.html|SRFI-11]] and is also
 901compatible with the definition from the R7RS {{(scheme base)}}
 902library.
 903
 904<enscript highlight=scheme>
 905(let*-values (((a b) (values 2 3))
 906              ((p) (+ a b)) )
 907  p)                               ==> 5
 908</enscript>
 909
 910==== letrec-values
 911
 912<macro>(letrec-values (((NAME ...) VALUEEXP) ...) BODY ...)</macro>
 913
 914Binds the result values of {{VALUEEXP ...}} to multiple variables at
 915once.  All variables are mutually recursive.  Like {{let-values}}, the
 916{{(NAME ...)}} expression can be any basic lambda list (dotted tail
 917notation is supported).
 918
 919<enscript highlight=scheme>
 920(letrec-values (((odd even)
 921                   (values
 922                     (lambda (n) (if (zero? n) #f (even (sub1 n))))
 923                     (lambda (n) (if (zero? n) #t (odd (sub1 n)))) ) ) )
 924  (odd 17) )                           ==> #t
 925</enscript>
 926
 927
 928==== receive
 929
 930<macro>(receive (NAME ...) VALUEEXP BODY ...)</macro><br>
 931<macro>(receive (NAME1 ... NAMEn . NAMEn+1) VALUEEXP BODY ...)</macro><br>
 932<macro>(receive NAME VALUEEXP BODY ...)</macro><br>
 933<macro>(receive VALUEEXP)</macro>
 934
 935[[http://srfi.schemers.org/srfi-8/srfi-8.html|SRFI-8]].
 936Syntactic sugar for {{call-with-values}}. Binds variables
 937to the result values of {{VALUEEXP}} and evaluates {{BODY ...}},
 938similar {{define-values}} but lexically scoped.
 939
 940{{(receive VALUEEXP)}} is equivalent to {{(receive _ VALUEEXP _)}}.
 941This shortened form is not described by SRFI-8.
 942
 943==== set!-values
 944
 945<macro>(set!-values (NAME ...) VALUEEXP)</macro>
 946<macro>(set!-values (NAME1 ... NAMEn . NAMEn+1) VALUEEXP)</macro>
 947<macro>(set!-values NAME VALUEEXP)</macro>
 948
 949Assigns the result values of expression {{VALUEEXP}} to multiple
 950variables, similar to {{define-values}}.
 951
 952==== nth-value
 953
 954<macro>(nth-value N EXP)</macro>
 955
 956Returns the {{N}}th value (counting from zero) of the values returned
 957by expression {{EXP}}.
 958
 959
 960=== Substitution forms and macros
 961
 962==== define-constant
 963
 964<macro>(define-constant NAME CONST)</macro>
 965
 966Defines a variable with a constant value, evaluated at compile-time.
 967Any reference to such a constant should appear textually '''after'''
 968its definition. This construct is equivalent to {{define}} when
 969evaluated or interpreted.  Constant definitions should only appear at
 970toplevel. Note that constants are local to the current compilation
 971unit and are not available outside of the source file in which they
 972are defined. Names of constants still exist in the Scheme namespace
 973and can be lexically shadowed.  If the value is mutable, then the
 974compiler is careful to preserve its identity.  {{CONST}} may be any
 975constant expression, and may also refer to constants defined via
 976{{define-constant}} previously, but it must be possible to
 977evaluate the expression at compile-time.
 978
 979==== define-inline
 980
 981<macro>(define-inline (NAME VAR ...) BODY ...)</macro><br>
 982<macro>(define-inline (NAME VAR ... . VAR) BODY ...)</macro><br>
 983<macro>(define-inline NAME EXP)</macro>
 984
 985Defines an inline procedure. Any occurrence of {{NAME}} will be replaced
 986by {{EXP}} or {{(lambda (VAR ... [. VAR]) BODY ...)}}. This is similar
 987to a macro, but variable names and scope are handled correctly.
 988
 989Inline substitutions take place '''after''' macro-expansion, and any
 990reference to {{NAME}} should appear textually '''after''' its
 991definition. Inline procedures are local to the current compilation unit
 992and are not available outside of the source file in which they are
 993defined. Names of inline procedures still exist in the Scheme namespace
 994and can be lexically shadowed. Inline definitions should only appear at
 995the toplevel.
 996
 997Note that the {{inline-limit}} compiler option does not affect inline
 998procedure expansion, and self-referential inline procedures may cause
 999the compiler to enter an infinite loop.
 1000
1001In the third form, {{EXP}} must be a lambda expression.
1002
1003This construct is equivalent to {{define}} when evaluated or
1004interpreted.
1005
1006
1007=== Conditional forms
1008
1009==== unless
1010
1011<macro>(unless TEST EXP1 EXP2 ...)</macro>
1012
1013Equivalent to:
1014
1015<enscript highlight=scheme>
1016(if (not TEST) (begin EXP1 EXP2 ...))
1017</enscript>
1018
1019==== when
1020
1021<macro>(when TEST EXP1 EXP2 ...)</macro>
1022
1023Equivalent to:
1024
1025<enscript highlight=scheme>
1026(if TEST (begin EXP1 EXP2 ...))
1027</enscript>
1028
1029=== Record structures
1030
1031==== define-record
1032
1033<macro>(define-record NAME SLOTNAME ...)</macro>
1034
1035Defines a record type. This defines a number of procedures for
1036creating, accessing, and modifying record members.
1037
1038Call {{make-NAME}} to create an instance
1039of the structure (with one initialization-argument for each slot, in
1040the listed order).
1041
1042{{(NAME? STRUCT)}} tests any object for being an instance of this
1043structure.
1044
1045Slots are accessed via {{(NAME-SLOTNAME STRUCT)}}
1046and updated using {{(NAME-SLOTNAME-set!}} {{STRUCT}} {{VALUE)}}.
1047
1048<enscript highlight=scheme>
1049(define-record point x y)
1050(define p1 (make-point 123 456))
1051(point? p1)                      ==> #t
1052(point-x p1)                     ==> 123
1053(point-y-set! p1 99)
1054(point-y p1)                     ==> 99
1055</enscript>
1056
1057===== SRFI-17 setters
1058
1059{{SLOTNAME}} may alternatively also be of the form
1060
1061  (setter SLOTNAME)
1062
1063In this case the slot can be read with {{(NAME-SLOTNAME STRUCT)}} as usual,
1064and modified with {{(set! (NAME-SLOTNAME STRUCT) VALUE)}} (the slot-accessor
1065has an associated SRFI-17 "setter" procedure) instead of
1066the usual {{(NAME-SLOTNAME-set!}} {{STRUCT}} {{VALUE)}}.
1067
1068
1069<enscript highlight=scheme>
1070(define-record point (setter x) (setter y))
1071(define p1 (make-point 123 456))
1072(point? p1)                      ==> #t
1073(point-x p1)                     ==> 123
1074(set! (point-y p1) 99)
1075(point-y p1)                     ==> 99
1076</enscript>
1077
1078==== define-record-type
1079
1080<macro>(define-record-type NAME (CONSTRUCTOR TAG ...) PREDICATE (FIELD ACCESSOR [MODIFIER]) ...)</macro>
1081
1082SRFI-9 record types. For more information see the documentation for
1083[[http://srfi.schemers.org/srfi-9/srfi-9.html|SRFI-9]].
1084
1085As an extension the {{MODIFIER}} may have the form
1086{{(setter PROCEDURE)}}, which will define a SRFI-17 setter-procedure
1087for the given {{PROCEDURE}} that sets the field value.
1088Usually {{PROCEDURE}} has the same name is {{ACCESSOR}} (but it
1089doesn't have to).
1090
1091This special form is also compatible with the definition from the R7RS
1092{{(scheme base)}} library.
1093
1094==== record-printer
1095
1096<procedure>(record-printer NAME)</procedure><br>
1097
1098Returns the procedure used to print records of the type {{NAME}} if
1099one has been set with {{set-record-printer!}}, {{#f}} otherwise.
1100
1101==== set-record-printer!
1102
1103<procedure>(set-record-printer! NAME PROCEDURE)</procedure><br>
1104<procedure>(set! (record-printer NAME) PROCEDURE)</procedure>
1105
1106Defines a printing method for record of the type {{NAME}} by
1107associating a procedure with the record type. When a record of this
1108type is written using {{display, write}} or {{print}}, then
1109the procedure is called with two arguments: the record to be printed
1110and an output-port.
1111
1112<enscript highlight=scheme>
1113(define-record-type foo (make-foo x y z) foo?
1114  (x foo-x)
1115  (y foo-y)
1116  (z foo-z))
1117(define f (make-foo 1 2 3))
1118(set-record-printer! foo
1119  (lambda (x out)
1120    (fprintf out "#,(foo ~S ~S ~S)"
1121             (foo-x x) (foo-y x) (foo-z x))))
1122(define-reader-ctor 'foo make-foo)
1123(define s (with-output-to-string
1124              (lambda () (write f))))
1125s                                   ==> "#,(foo 1 2 3)"
1126(equal? f (with-input-from-string
1127              s read)))             ==> #t
1128</enscript>
1129
1130=== Other forms
1131
1132==== load
1133
1134<procedure>(load filename [evalproc])</procedure><br>
1135
1136Filename should be a string naming an existing file containing Scheme
1137source code. The load procedure reads expressions and definitions from
1138the file and evaluates them sequentially. It is unspecified whether the
1139results of the expressions are printed. The load procedure does not
1140affect the values returned by current-input-port and
1141current-output-port. Load returns an unspecified value.
1142
1143CHICKEN offers a few extensions to the R7RS definition of {{load}}:
1144
1145* The {{filename}} may also be an input port.
1146* The expressions which are read one by one from the source file are passed to the procedure indicated by the extra optional {{evalproc}} argument, which defaults to {{eval}}.
1147* On platforms that support it (currently BSD, Haiku, MacOS X, Linux, Solaris, and Windows), {{load}} can be used to load shared objects.
1148
1149Example for loading compiled programs:
1150
1151 % cat x.scm
1152 (define (hello) (print "Hello!"))
1153 % csc -s x.scm
1154 % csi -q
1155 #;1> (load "x.so")
1156 ; loading x.so ...
1157 #;2> (hello)
1158 Hello!
1159 #;3>
1160
1161There are some limitations and caveats to the CHICKEN extensions you
1162need to be aware of:
1163
1164* The second argument to {{load}} is ignored when loading compiled code.
1165* If source code is loaded from a port, then that port is closed after all expressions have been read.
1166* A compiled file can only be loaded once. Subsequent attempts to load the same file have no effect.
1167
1168==== include
1169
1170<macro>(include STRING1 STRING2 ...)</macro>
1171<macro>(include-ci STRING1 STRING2 ...)</macro>
1172
1173Include toplevel-expressions from the given source files in the currently
1174compiled/interpreted program.  If the included file has the extension
1175{{.scm}}, then it may be omitted. The file is searched for in the
1176current directory and all directories specified by the {{-include-path}}
1177option.
1178
1179{{include-ci}} works as {{include}} but reads files in case-insensitive
1180mode.
1181
1182==== include-relative
1183
1184<macro>(include-relative STRING)</macro>
1185
1186Works like {{include}}, but the filename is searched for relative to the
1187including file rather than the current directory.
1188
1189
1190=== Making extra libraries and extensions available
1191
1192==== require-extension
1193
1194<macro>(require-extension ID ...)</macro>
1195
1196This is equivalent to {{(require-library ID ...)}} but performs an implicit
1197{{import}}, if necessary. Since version 4.4.0, {{ID}} may also be an import specification
1198(using {{rename}}, {{only}}, {{except}} or {{prefix}}).
1199
1200To make long matters short - just use {{require-extension}} and it will normally figure everything out for dynamically
1201loadable extensions and core library units.
1202
1203This implementation of {{require-extension}} is compliant with [[http://srfi.schemers.org/srfi-55/srfi-55.html|SRFI-55]]
1204(see the [[http://srfi.schemers.org/srfi-55/srfi-55.html|SRFI-55]] document for more information).
1205
1206
1207==== require-library
1208
1209<macro>(require-library ID ...)</macro>
1210
1211This form does all the necessary steps to make the libraries or extensions given
1212in {{ID ...}} available. It loads syntactic extensions, if needed and generates
1213code for loading/linking with core library modules or separately installed
1214extensions.
1215
1216During interpretation/evaluation {{require-library}} performs one of the
1217following:
1218
1219* If {{ID}} names a built-in feature, then nothing is done.
1220* If {{ID}} names one of the syntactic extensions {{chicken-syntax chicken-ffi-syntax}}, then this extension will be loaded.
1221* If {{ID}} names one of the core library units shipped with CHICKEN, then a {{(load-library 'ID)}} will be performed.
1222* If {{ID}} names an installed extension with the {{syntax}} or {{require-at-runtime}} attribute, then the extensions is loaded at compile-time, probably doing a run-time {{(require ...)}} for any run-time requirements.
1223* Otherwise, {{(require-library ID)}} is equivalent to {{(require 'ID)}}.
1224
1225During compilation, one of the following happens instead:
1226
1227* If {{ID}} names a built-in feature, then nothing is done.
1228* If {{ID}} names one of the syntactic extensions {{chicken-syntax chicken-ffi-syntax}}, then this extension will be loaded at compile-time, making the syntactic extensions available in compiled code.
1229* If {{ID}} names one of the core library units shipped with CHICKEN, or if the option {{-uses ID}} has been passed to the compiler, then a {{(declare (uses ID))}} is generated.
1230* If {{ID}} names an installed extension with the {{syntax}} or {{require-at-runtime}} attribute, then the extension is loaded at compile-time, and code is emitted to {{(require ...)}} any needed run-time requirements.
1231* Otherwise {{(require-library ID)}} is equivalent to {{(require 'ID)}}.
1232
1233{{ID}} should be a pure extension name and should not contain any path prefixes (for example {{dir/lib...}} is illegal).
1234
1235{{ID}} may also be a list that designates an extension-specifier. Currently the following extension specifiers are
1236defined:
1237
1238* {{(srfi NUMBER ...)}} is required for SRFI-55 compatibility and is fully implemented
1239* {{(version ID NUMBER)}} is equivalent to {{ID}}, but checks at compile-time whether the extension named {{ID}} is installed and whether its version is equal or higher than {{NUMBER}}. {{NUMBER}} may be a string or a number, the comparison is done lexicographically (using {{string>=?}}).
1240
1241=== Process shutdown
1242
1243==== emergency-exit
1244
1245<procedure>(emergency-exit [CODE])</procedure>
1246
1247Exits the current process without flushing any buffered output (using
1248the C function {{_exit}}).  Note that the {{exit-handler}} is not called
1249when this procedure is invoked. The optional exit status code {{CODE}}
1250defaults to {{0}}.
1251
1252
1253==== exit
1254
1255<procedure>(exit [CODE])</procedure>
1256
1257Exit the running process and return exit-code, which defaults to 0
1258(Invokes {{exit-handler}}).
1259
1260Note that pending {{dynamic-wind}} thunks are ''not'' invoked when exiting your program in this way.
1261
1262
1263=== exit-handler
1264
1265<parameter>(exit-handler)</parameter>
1266
1267A procedure of a single optional argument. When {{exit}} is called,
1268then this procedure will be invoked with the exit-code as argument. The
1269default behavior is to terminate the program.
1270
1271Note that this handler is ''not'' invoked when {{emergency-exit}} is
1272used.
1273
1274
1275=== implicit-exit-handler
1276
1277<parameter>(implicit-exit-handler)</parameter>
1278
1279A procedure of no arguments. When the last toplevel expression of the
1280program has executed, then the value of this parameter is called. The
1281default behaviour is to invoke all pending finalizers.
1282
1283
1284==== on-exit
1285
1286<procedure>(on-exit THUNK)</procedure>
1287
1288Schedules the zero-argument procedures {{THUNK}} to be executed before
1289the process exits, either explicitly via {{exit}} or implicitly after
1290execution of the last top-level form. Note that finalizers for
1291unreferenced finalized data are run before exit procedures.
1292
1293
1294=== System interface
1295
1296
1297==== sleep
1298
1299<procedure>(sleep SECONDS)</procedure>
1300
1301Puts the program to sleep for {{SECONDS}}. If the scheduler is loaded
1302(for example when srfi-18 is in use) then only the calling thread is put
1303to sleep and other threads may continue executing. Otherwise, the whole
1304process is put to sleep.
1305
1306
1307=== File Input/Output
1308
1309==== flush-output
1310
1311<procedure>(flush-output [PORT])</procedure>
1312
1313Write buffered output to the given output-port. {{PORT}} defaults
1314to the value of {{(current-output-port)}}.
1315
1316=== Port predicates
1317
1318==== port-closed?
1319
1320<procedure>(port-closed? PORT)</procedure>
1321
1322Is the given {{PORT}} closed (in all directions)?
1323
1324
1325=== Built-in parameters
1326
1327Certain behavior of the interpreter and compiled programs can be
1328customized via the following built-in parameters:
1329
1330==== case-sensitive
1331
1332<parameter>(case-sensitive)</parameter>
1333
1334If true, then {{read}} reads symbols and identifiers in
1335case-sensitive mode and uppercase characters in symbols are printed
1336escaped. Defaults to {{#t}}.
1337
1338
1339==== keyword-style
1340
1341<parameter>(keyword-style)</parameter>
1342
1343Enables alternative keyword syntax, where {{STYLE}} may be either
1344{{#:prefix}} (as in Common Lisp), which recognizes symbols beginning
1345with a colon as keywords, or {{#:suffix}} (as in DSSSL), which recognizes
1346symbols ending with a colon as keywords.
1347Any other value disables the alternative syntaxes.  In the interpreter
1348the default is {{#:suffix}}.
1349
1350
1351==== parentheses-synonyms
1352
1353<parameter>(parentheses-synonyms)</parameter>
1354
1355If true, then the list delimiter synonyms {{#\[}} {{#\]}} and {{#\{}} {{#\}}} are enabled. Defaults to {{#t}}.
1356
1357
1358==== symbol-escape
1359
1360<parameter>(symbol-escape)</parameter>
1361
1362If true, then the symbol escape {{#\|}} {{#\|}} is allowed when reading
1363and printing expressions. Defaults to {{#t}}.
1364
1365
1366---
1367Previous: [[Module srfi-4]]
1368
1369Next: [[Module (chicken bitwise)]]
Trap